package cn.csc.module.product.service.collect;

import cn.csc.framework.common.pojo.PageResult;
import cn.csc.module.product.controller.admin.collect.vo.SpuCollectCreateReqVO;
import cn.csc.module.product.controller.admin.collect.vo.SpuCollectExportReqVO;
import cn.csc.module.product.controller.admin.collect.vo.SpuCollectPageReqVO;
import cn.csc.module.product.controller.admin.collect.vo.SpuCollectUpdateReqVO;
import cn.csc.module.product.dal.dataobject.collect.SpuCollectDO;

import javax.validation.Valid;
import java.math.BigInteger;
import java.util.Collection;
import java.util.List;

/**
 * 收藏商品信息 Service 接口
 *
 * @author 华南城
 */
public interface SpuCollectService {

    /**
     * 创建收藏商品信息
     *
     * @param createReqVO 创建信息
     * @return 编号
     */
    BigInteger createSpuCollect(@Valid SpuCollectCreateReqVO createReqVO);

    /**
     * 更新收藏商品信息
     *
     * @param updateReqVO 更新信息
     */
    void updateSpuCollect(@Valid SpuCollectUpdateReqVO updateReqVO);

    /**
     * 删除收藏商品信息
     *
     * @param id 编号
     */
    void deleteSpuCollect(BigInteger id);

    void delSpuCollect(SpuCollectCreateReqVO createReqVO);

    /**
     * 获得收藏商品信息
     *
     * @param id 编号
     * @return 收藏商品信息
     */
    SpuCollectDO getSpuCollect(BigInteger id);

    /**
     * 获得收藏商品信息列表
     *
     * @param ids 编号
     * @return 收藏商品信息列表
     */
    List<SpuCollectDO> getSpuCollectList(Collection<BigInteger> ids);

    /**
     * 获得收藏商品信息分页
     *
     * @param pageReqVO 分页查询
     * @return 收藏商品信息分页
     */
    PageResult<SpuCollectDO> getSpuCollectPage(SpuCollectPageReqVO pageReqVO);

    /**
     * 获得收藏商品信息列表, 用于 Excel 导出
     *
     * @param exportReqVO 查询条件
     * @return 收藏商品信息列表
     */
    List<SpuCollectDO> getSpuCollectList(SpuCollectExportReqVO exportReqVO);

    SpuCollectDO getSpuByOne(SpuCollectCreateReqVO createReqVO);

}
